home *** CD-ROM | disk | FTP | other *** search
/ GameStar 2004 April / Gamestar_61_2004-04_dvdb.iso / DVDStar / Editace / hltp.exe / {app} / Applications / QuArK / quarkpy / maptools.py < prev    next >
Text File  |  2004-01-05  |  5KB  |  81 lines

  1. """   QuArK  -  Quake Army Knife
  2.  
  3. The map editor's "Toolbars" menu (to be extended by plug-ins)
  4. """
  5. #
  6. # Copyright (C) 1996-99 Armin Rigo
  7. # THIS FILE IS PROTECTED BY THE GNU GENERAL PUBLIC LICENCE
  8. # FOUND IN FILE "COPYING.TXT"
  9. #
  10.  
  11. #$Header: /cvsroot/quark/runtime/quarkpy/maptools.py,v 1.5 2003/03/15 20:42:09 cdunde Exp $
  12.  
  13.  
  14. import qmenu
  15. from maputils import *
  16.  
  17.  
  18. #
  19. # The base ToolBar class is imported from qeditor.py.
  20. #
  21.  
  22. class DisplayBar(ToolBar):
  23.     "The standard Display tool bar."
  24.  
  25.     Caption = "Display"
  26.     DefaultPos = ((0,0,0,0), "topdock", 0, 0, 1)
  27.  
  28.     def buildbuttons(self, layout):
  29.         ico_maped=ico_dict['ico_maped']
  30.         gridbtn = qtoolbar.doublebutton(layout.editor.togglegrid, layout.getgridmenu, "Grid||Grid:\n\nThe grid is the pattern of dots on the map that 'snaps' mouse moves. It helps you align polyhedrons and entities. You should always keep it active; otherwise, you could create slightly misaligned polyhedrons with small gaps between them, which is very bad for the game.\n\nThis 'grid' button has two parts : you can click either on the icon and get a menu that lets you select the grid size you like, or you can click on the text itself, which toggles the grid on/off without hiding it. As noted above, be careful when the grid is off.", ico_maped, 7, infobaselink="intro.mapeditor.toolpalettes.display.html#grid")
  31.  
  32.         gridbtn.caption = "128"  # to determine the button width
  33.  
  34.         zoombtn = qtoolbar.doublebutton(layout.autozoom1click, getzoommenu, "Choose zoom factor / zoom to fit the level or the selection||Choose zoom factor:\n\nThis button lets you zoom in or out. This button has two parts.\n\nClick on the icon to get a list of common zoom factors, or to enter a custom factor with the keyboard.\n\nClick on the text ('zoom') besides the icon to 'auto-zoom' in and out : the first time you click, the scale is choosen so that you can see the whole level at a glance; the second time you click, the views zoom in on the selected objects.", ico_maped, 14, infobaselink="intro.mapeditor.toolpalettes.display.html#zoom")
  35.         zoombtn.near = 0
  36.         zoombtn.views = layout.views
  37.         zoombtn.caption = "zoom"
  38.  
  39.         Btn3D = qtoolbar.button(layout.new3Dwindow, "New 3D window||New 3D window:\n\nThis will create a new floating 3D-window, which you can place anywhere on your desktop.\nIt only exist as long as you are in the map editor.", ico_maped, 20, infobaselink="intro.mapeditor.toolpalettes.display.html#3dwindows")
  40.  
  41.         BtnFull3D = qtoolbar.button(layout.full3Dclick, "Full 3D view||Full 3D view:\n\nThis will take you to a full-screen 3D-display.\nYou must press Escape to return to the map editor.", ico_maped, 21, infobaselink="intro.mapeditor.toolpalettes.display.html#3dwindows")
  42.  
  43.         BtnOpenGL = qtoolbar.button(layout.toggleOpenGLwindow, "OpenGL 3D view||OpenGL 3D view:\n\nThis will create a new floating OpenGL 3D-window, where you will be able to preview your light effects.", ico_maped, 27, infobaselink="intro.mapeditor.toolpalettes.display.html#3dwindows")
  44.  
  45.         LinearVBtn = qtoolbar.button(layout.editor.linear1click, "Linear mapping circle on selection||Linear mapping circle on selection:\n\nWhen this button is selected, QuArK always displays a pink circle around the selected objects; otherwise, it only appears if multiple objects are selected.\n\nThis circle and its attached handles let you apply 'linear mappings' on the objects. 'Linear mapping' means any transformation like rotation, enlarging/shrinking, symmetry, or a combination of them all. When you use the rotate, enlarge, shrink, and symmetry buttons of the movement tool palette, you actually apply a linear mapping on the selected objects. This is only interesting to know for a special kind of Duplicators, the one that can apply linear mappings. It means that this kind of Duplicator can create images with any of the previous movement commands applied, for example to create spiral stairs.", ico_maped, 19,  infobaselink="intro.mapeditor.toolpalettes.display.html#linear")
  46.  
  47.         LockViewsBtn = qtoolbar.button(layout.editor.lockviewsclick, "Lock views||Lock views:\n\nThis will cause all of the 2D views to move and zoom together.\n\nWhen this is in the unlocked mode, the 2d views can then be moved and zoomed on individually.\n\nIf the lock is reset then the 2D views will realign themselves.", ico_maped, 28)
  48.  
  49.         helpbtn = qtoolbar.button(layout.helpbtnclick, "Contextual help||Contextual help:\n\nWill open up your web-browser, and display the QuArK main help page.", ico_maped, 13, infobaselink="intro.mapeditor.toolpalettes.display.html#helpbook")
  50.  
  51.         layout.buttons.update({"grid": gridbtn, "linear": LinearVBtn, "opengl": BtnOpenGL, "lockv": LockViewsBtn})
  52.  
  53.         return [gridbtn, zoombtn, Btn3D, BtnFull3D, BtnOpenGL, LinearVBtn, LockViewsBtn, helpbtn]
  54.  
  55.  
  56. #
  57. # Initialize "toolbars" with the standard tool bars. Plug-ins can
  58. # register their own toolbars in the "toolbars" dictionnary.
  59. #
  60.  
  61. import qmovepal
  62. toolbars = {"tb_display": DisplayBar, "tb_movepal": qmovepal.ToolMoveBar}
  63.  
  64. # ----------- REVISION HISTORY ------------
  65. #
  66. #
  67. #$Log: maptools.py,v $
  68. #Revision 1.5  2003/03/15 20:42:09  cdunde
  69. #To update hints and add infobase links
  70. #
  71. #Revision 1.4  2003/02/14 03:12:55  cdunde
  72. #To add F1 help popup info
  73. #
  74. #Revision 1.3  2001/10/22 10:24:32  tiglari
  75. #live pointer hunt, revise icon loading
  76. #
  77. #Revision 1.2  2000/06/02 16:00:22  alexander
  78. #added cvs headers
  79. #
  80. #
  81. #